/*
 * Copyright (c) 2025 Huawei Device Co., Ltd.
 * Licensed under the Apache License, Version 2.0 (the "License"),
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

/**
 * @addtogroup TeeTrusted
 * @{
 *
 * @brief TEE（Trusted Excution Environment）可信执行环境API。
 *
 * 提供安全能力API，例如可信存储、加解密及可信时间等，用于可信应用程序开发。
 *
 * @since 20
 */

/**
 * @file pthread_attr.h
 *
 * @brief 提供关于TA多线程的属性。
 *
 * @library NA
 * @kit TEEKit
 * @include <TEEKit/pthread_attr.h>
 * @syscap SystemCapability.Tee.TeeClient
 * @since 20
 */

#ifndef PTHREAD_ATTR_H
#define PTHREAD_ATTR_H

#include <pthread.h>

#ifdef __cplusplus
extern "C" {
#endif

/**
 * @brief 定义CA的线程属性未显式设置（通配符/默认状态）。
 *
 * @since 20
 */
#define TEESMP_THREAD_ATTR_CA_WILDCARD 0

/**
 * @brief 定义CA的线程属性继承自父线程。
 *
 * @since 20
 */
#define TEESMP_THREAD_ATTR_CA_INHERIT (-1U)

/**
 * @brief 定义任务ID属性继承自父任务/线程。
 *
 * @since 20
 */
#define TEESMP_THREAD_ATTR_TASK_ID_INHERIT (-1U)

/**
 * @brief 定义线程属性具有影子线程。
 *
 * @since 20
 */
#define TEESMP_THREAD_ATTR_HAS_SHADOW 0x1

/**
 * @brief 定义线程属性不具有影子线程。
 *
 * @since 20
 */
#define TEESMP_THREAD_ATTR_NO_SHADOW 0x0

/**
 * @brief 设置CA、任务ID和影子线程的线程属性。
 *
 * @param a 指向要修改的线程属性对象的指针。
 * @param ca 指定CA属性值（例如：TEESMP_THREAD_ATTR_CA_INHERIT表示继承）。
 * @param task_id 指定任务ID属性值（例如：TEESMP_THREAD_ATTR_TASK_ID_INHERIT表示继承）。
 * @param shadow 指示是否启用影子线程设置（例如：TEESMP_THREAD_ATTR_NO_SHADOW为0x0表示无影子，TEESMP_THREAD_ATTR_HAS_SHADOW为0x1表示有影子）。
 *
 * @return 始终返回0。
 * @since 20
 */
int pthread_attr_settee(pthread_attr_t *a, int ca, int task_id, int shadow);

#ifdef __cplusplus
}
#endif

#endif
/** @} */